We really don't need atime for metadata, it's just a speed hit.
gboolean ret = FALSE;
int fd = -1;
- fd = g_open (ot_gfile_get_path_cached (file), O_RDONLY | O_NOATIME | O_CLOEXEC | O_LARGEFILE, 0);
- if (fd < 0)
- {
- ot_util_set_error_from_errno (error, errno);
- goto out;
- }
+ if (!ot_unix_open_noatime (ot_gfile_get_path_cached (file), &fd, error))
+ goto out;
if (!ot_unix_fdatasync (fd, error))
goto out;
#include "config.h"
+#define _GNU_SOURCE
+
#include "otutil.h"
#include <gio/gio.h>
+#include <glib/gstdio.h>
#include <gio/gunixoutputstream.h>
#include <string.h>
#include <sys/types.h>
+#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
#include <errno.h>
}
return TRUE;
}
+
+/**
+ * ot_unix_open_noatime:
+ *
+ * Open a file for reading, using O_NOATIME if possible.
+ */
+gboolean
+ot_unix_open_noatime (const char *path,
+ int *out_fd,
+ GError **error)
+{
+ int fd;
+
+#ifdef O_NOATIME
+ fd = g_open (path, O_RDONLY | O_NOATIME | O_CLOEXEC, 0);
+ if (fd == -1 && errno == EPERM)
+#endif
+ fd = g_open (path, O_RDONLY | O_CLOEXEC, 0);
+ if (fd == -1)
+ {
+ ot_util_set_error_from_errno (error, errno);
+ return FALSE;
+ }
+ *out_fd = fd;
+ return TRUE;
+}
gboolean ot_unix_close (int fd, GError **error);
+gboolean ot_unix_open_noatime (const char *path, int *out_fd, GError **error);
+
G_END_DECLS
#endif
const char *path = NULL;
ot_lvariant GVariant *ret_variant = NULL;
GMappedFile *mfile = NULL;
+ int fd;
path = ot_gfile_get_path_cached (src);
- mfile = g_mapped_file_new (path, FALSE, error);
+ if (!ot_unix_open_noatime (path, &fd, error))
+ goto out;
+ mfile = g_mapped_file_new_from_fd (fd, FALSE, error);
if (!mfile)
goto out;
+ if (!ot_unix_close (fd, error))
+ goto out;
ret_variant = g_variant_new_from_data (type,
g_mapped_file_get_contents (mfile),